<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org" lang="en">
<head>
    <meta charset="UTF-8">
    <title>公告管理</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta http-equiv="Access-Control-Allow-Origin" content="*">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="format-detection" content="telephone=no">
    <link rel="stylesheet" th:href="@{/layui/css/layui.css}" media="all"/>
    <link rel="stylesheet" th:href="@{/css/public.css}" media="all"/>
</head>
<body class="childrenBody">
<!--查询条件开始-->
<blockquote class="layui-elem-quote">
    <form action="" method="post" id="searchFrm" lay-filter="searchFrm" class="layui-form layui-form-pane">
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">公告标题</label>
                <div class="layui-input-inline">
                    <input type="text" name="title" autocomplete="off"
                           class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">发布人</label>
                <div class="layui-input-inline">
                    <input type="text" name="opername"
                           autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">开始时间</label>
                <div class="layui-input-inline">
                    <input type="tel" name="startTime" id="startTime" readonly="readonly"
                           placeholder="yyyy-MM-dd HH:mm:ss"
                           autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">结束时间</label>
                <div class="layui-input-inline">
                    <input type="tel" name="endTime" id="endTime" readonly="readonly" placeholder="yyyy-MM-dd HH:mm:ss"
                           autocomplete="off"
                           class="layui-input">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-input-block" style="text-align: center;">
                <button type="button" class="layui-btn" lay-submit="" lay-filter="doSearch"><span
                        class="layui-icon layui-icon-search"></span>查询
                </button>
                <button type="reset" class="layui-btn layui-btn-warm"><span
                        class="layui-icon layui-icon-refresh-1"></span>重置
                </button>
            </div>
        </div>
    </form>
</blockquote>
<!--查询条件结束-->

<!--数据表格开始-->
<div>
    <table class="layui-hide" id="noticeTable" lay-filter="noticeTable"></table>
    <div id="noticeToolBar" style="display: none;">
        <button type="button" lay-event="add" class="layui-btn  layui-btn-sm ">
            <span class="layui-icon ">&#xe608;</span>添加公告
        </button>
        <button type="button" lay-event="batchDelete" class="layui-btn  layui-btn-sm layui-btn-danger">
            <span class="layui-icon layui-icon-delete"></span>批量删除
        </button>
    </div>
    <div id="noticeRowBar" style="display: none;">
        <button type="button" lay-event="show" class="layui-btn layui-btn-sm ">
            <span class="layui-icon layui-icon-list"></span>查看
        </button>
        <button type="button" lay-event="update" class="layui-btn layui-btn-sm  layui-btn-warm">
            <span class="layui-icon layui-icon-edit"></span>修改
        </button>
        <button type="button" lay-event="delete" class="layui-btn layui-btn-sm  layui-btn-danger">
            <span class="layui-icon layui-icon-delete"></span>删除
        </button>

    </div>
</div>
<!--数据表格结束-->
<!--查询公告弹出层开始-->
<div style="display: none; padding: 5px;" id="showNoticeDiv">
    <h2 id="show_title" align="center"></h2>
    <div style="text-align: right;">
        发布人：<span id="show_opername"></span>
        发布时间：<span id="show_createtime"></span>
    </div>
    <hr class="layui-bg-black">
    <div id="show_content"></div>
</div>
<!--查询公告弹出层结束-->

<!--添加和修改的弹出层开始-->
<div style="display: none; padding: 6px" id="addOrUpdateDiv">
    <form action="" method="post" class="layui-form layui-form-pane" id="dataFrm" lay-filter="dataFrm">
        <div class="layui-form-item">
            <label class="layui-form-label">公告标题</label>
            <div class="layui-input-block">
                <input type="hidden" name="id">
                <input type="text" name="title" lay-verify="required" autocomplete="off" placeholder="请输入标题"
                       class="layui-input">
            </div>
        </div>

        <div class="layui-form-item">
            <label class="layui-form-label">公告内容</label>
            <div class="layui-input-block">
                <textarea class="layui-textarea " name="content" lay-verify="content" id="content"></textarea>
            </div>
        </div>

        <div class="layui-form-item">
            <div class="layui-input-block" style="text-align: center;">
                <button type="button" class="layui-btn" lay-submit="" id="doSubmit"><span
                        class="layui-icon layui-icon-add-1"></span>提交
                </button>
                <button type="reset" class="layui-btn layui-btn-warm"><span
                        class="layui-icon layui-icon-refresh-1"></span>重置
                </button>
            </div>
        </div>
    </form>
</div>

<!--添加和修改的弹出层结束-->

<script type="text/javascript" th:src="@{/layui/layui.js}"></script>
<script type="text/javascript">
    layui.use(['jquery', 'form', 'table', 'layer', 'laydate', 'layedit'], function () {
            var $ = layui.jquery;
            var form = layui.form;
            var table = layui.table;
            var layer = layui.layer;
            var laydate = layui.laydate;
            var layedit = layui.layedit;

            //初始化时间选择器
            laydate.render({
                elem: '#startTime',
                type: 'datetime'
            });
            laydate.render({
                elem: '#endTime',
                type: 'datetime'
            });

            //加载数据
            var tableIns = table.render({
                elem: '#noticeTable'
                , url: '/notice/loadAllNotice'
                , toolbar: '#noticeToolBar' //开启头部工具栏，并为其绑定左侧模板
                , title: '公告数据表'
                , height: 'full-175'
                , page: true
                , cols: [ [  //中括号中间需要空格！！！
                    {type: 'checkbox', fixed: 'left'}
                    , {field: 'id', title: 'ID', align: 'center'}
                    , {field: 'title', title: '标题', align: 'center'}
                    , {field: 'opername', title: '发布人', align: 'center'}
                    , {field: 'createtime', title: '发布时间', align: 'center'}
                    , {fixed: 'right', title: '操作', toolbar: '#noticeRowBar', align: 'center'}
                ] ]
            });
            //模糊查询
            form.on("submit(doSearch)", function (data) {
                tableIns.reload({
                    where: data.field,
                    page: {
                        curr: 1
                    }
                });
                return false;
            });
            //监听工具条的事件
            table.on('toolbar(noticeTable)', function (obj) {
                switch (obj.event) {
                    case 'batchDelete':
                        batchDelete();
                        break;
                    case 'add':
                        openAddLayer();
                        break;
                }
                ;
            });
            //监听工具条的事件
            table.on('tool(noticeTable)', function (obj) {
                var data = obj.data;
                switch (obj.event) {
                    case 'show':
                        showNotice(data);
                        break;
                    case 'update':
                        openUpdateNoticeLayer(data);
                        break;
                    case 'delete':
                        deleteInfo(data);
                        break;
                }
                ;
            });

            //打开修改的弹出层
            function openUpdateNoticeLayer(data) {
                mainIndex = layer.open({
                    type: 1,
                    content: $('#addOrUpdateDiv'),
                    area: ['800px', '550px'],
                    title: '修改公告',
                    success: function () {
                        $("#dataFrm")[0].reset();
                        //装载新的数据
                        form.val("dataFrm", data);
                        layedit.setContent(editIndex, data.content);
                        url = "/notice/updateNotice";
                    }
                });
            }

            var mainIndex;
            //创建一个编辑器
            var editIndex = layedit.build('content');

            //打开添加或修改弹出层
            function openAddLayer() {
                mainIndex = layer.open({
                    type: 1,
                    content: $('#addOrUpdateDiv'),
                    area: ['800px', '550px'],
                    title: '发布公告',
                    success: function () {
                        $("#dataFrm")[0].reset();
                        layedit.setContent(editIndex, "");
                        //初始化富文本
                        url = "/notice/addNotice";
                    }
                });
            }

            //添加和修改的提交
            $("#doSubmit").click(function () {
                //同步富文本和textarea里面的内容
                layedit.sync(editIndex);
                //表单序列化
                var data = $("#dataFrm").serialize();
                $.post(url, data, function (res) {
                    if (res.code == 200) {
                        tableIns.reload();
                    }
                    layer.msg(res.msg);
                    layer.close(mainIndex);
                })
            });

            //删除
            function deleteInfo(data) {
                //获得当前行数据
                //需要添加提示语句
                layer.confirm('你确定要删除【' + data.title + '】这条公告吗?', {icon: 3, title: '提示'}, function (index) {
                    $.post("/notice/deleteNotice", {id: data.id}, function (res) {
                        if (res.code == 200) {
                            tableIns.reload();
                        }
                        layer.msg(res.msg);
                    })
                    layer.close(index);
                });
            }

            //批量删除
            function batchDelete() {
                //得到选中行
                var checkStatus = table.checkStatus("noticeTable");
                var dataLength = checkStatus.data.length;//获取选中行的长度
                var data = checkStatus.data;//获取选中的行数的数据
                if (dataLength > 0) {
                    //需要添加提示语句
                    layer.confirm('你确定要删除这些公告吗?', {icon: 3, title: '提示'}, function (index) {
                        var ids = "";
                        $.each(data, function (index, item) {
                            if (index == 0) {
                                ids += "ids=" + item.id;
                            } else {
                                ids += "&ids=" + item.id;
                            }
                        });
                        $.post("/notice/batchDeleteNotice", ids, function (res) {
                            if (res.code == 200) {
                                tableIns.reload();
                            }
                            layer.msg(res.msg);
                        })
                        layer.close(index);
                    });
                } else {
                    layer.msg("请选中操作行");
                }
            }

            //弹出查看层
        function showNotice(data) {
            mainIndex = layer.open({
                type:1,
                content:$("#showNoticeDiv"),
                area:['800px','550px'],
                title:'查看公告',
                success:function () {
                    $("#show_title").html(data.title);
                    $("#show_opername").html(data.opername);
                    $("#show_createtime").html(data.createtime);
                    $("#show_content").html(data.content);
                }
            })
        }

        }
    );
</script>

</body>
</html>